table of contents
FCHMODAT(2) | Руководство программиста Linux | FCHMODAT(2) |
ИМЯ¶
fchmodat - изменяет пользовательские права на файл, определяемый относительно файлового дескриптора каталога
ОБЗОР¶
#include <fcntl.h> /* определения констант AT_* */ #include <sys/stat.h> int fchmodat(int dirfd, const char *pathname, mode_t mode, int flags);
Требования
макроса
тестирования
свойств
для glibc (см.
feature_test_macros(7)):
fchmodat():
- Начиная с glibc 2.10:
- _XOPEN_SOURCE >= 700 || _POSIX_C_SOURCE >= 200809L
- До glibc 2.10:
- _ATFILE_SOURCE
ОПИСАНИЕ¶
Системный вызов fchmodat() работает также как системный вызов chmod(2), за исключением случаев, описанных в данной справочной странице.
Если в pathname задан относительный путь, то он считается относительно каталога, на который ссылается файловый дескриптор dirfd (а не относительно текущего рабочего каталога вызывающего процесса, как это делается в chmod(2)).
Если в pathname задан относительный путь и dirfd равно специальному значению AT_FDCWD, то pathname рассматривается относительно текущего рабочего каталога вызывающего процесса (как chmod(2)).
Если в pathname задан абсолютный путь, то dirfd игнорируется.
Значение flags может быть 0, или включать следующие флаги:
- AT_SYMLINK_NOFOLLOW
- Если значение pathname является символьной ссылкой, не разыменовывать её, а изменить права на самой ссылке. Этот флаг пока не реализован.
ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ¶
При успешном выполнении fchmodat() возвращает 0; при ошибке — -1, а в errno задаётся причина ошибки.
ОШИБКИ¶
В fchmodat() могут возникнуть те же ошибки, что и в chmod(2). Также, в fchmodat() могут возникнуть следующие ошибки:
- EBADF
- dirfd не является правильным файловым дескриптором.
- EINVAL
- Указано неверное значение в flags.
- ENOTDIR
- Значение pathname содержит относительный путь и dirfd содержит файловый дескриптор, указывающий на файл, а не на каталог.
- ENOTSUP
- В flags указано AT_SYMLINK_NOFOLLOW, но оно не поддерживается.
ВЕРСИИ¶
Вызов fchmodat() был добавлен в ядро Linux версии 2.6.16; поддержка в glibc доступна с версии 2.4.
СООТВЕТСТВИЕ СТАНДАРТАМ¶
POSIX.1-2008.
ЗАМЕЧАНИЯ¶
Смотрите в openat(2) объяснение необходимости fchmodat().
В этой странице описана обёрточная функция библиотеки GNU C, которая реализует POSIX-интерфейс. Данный интерфейс отличается от лежащего в основе системного вызова Linux, который не имеет аргумента flags.
СМОТРИТЕ ТАКЖЕ¶
2012-05-22 | Linux |